<script setup lang="ts">
import { toRefs } from 'vue';
interface PropsInterface {
  label: string;
  name: string;
  placeholder?: string;
  autocomplete?: string;
  labelHidden?: boolean;
  required?: boolean;
  dialCode?: string;
  dialCodeList?: Array<string>;
  type?: string;
  hasError?: boolean;
  describedBy?: string;
}

const props = withDefaults(defineProps<PropsInterface>(), {
  label: 'Username',
  name: 'username',
  placeholder: '',
  autocomplete: '',
  required: true,
  type: 'text',
});

const {
  label,
  name,
  placeholder,
  autocomplete,
  labelHidden,
  required,
  dialCode,
  dialCodeList,
} = toRefs(props);

const random = Math.floor(Math.random() * 999999);
const randomPhone = Math.floor(Math.random() * 999999);
</script>

<template>
  <base-wrapper
    class="amplify-flex amplify-field amplify-textfield amplify-phonenumberfield"
  >
    <base-label
      :for="'amplify-field-' + random"
      class="amplify-label"
      :class="{ 'amplify-visually-hidden': labelHidden }"
      v-bind="$attrs"
    >
      {{ label }}
    </base-label>
    <base-wrapper class="amplify-flex amplify-field-group">
      <base-wrapper class="amplify-field-group__outer-start">
        <!--select drop down-->
        <base-wrapper
          class="amplify-flex amplify-field amplify-selectfield amplify-countrycodeselect amplify-dialcodeselect amplify-authenticator__column"
          v-if="type === 'tel'"
        >
          <base-label
            :for="'amplify-field-' + randomPhone"
            class="amplify-label amplify-visually-hidden"
            v-bind="$attrs"
          >
            {{ 'Country Code' }}
          </base-label>
          <base-wrapper class="amplify-select__wrapper">
            <base-select
              class="amplify-select amplify-field-group__control"
              :id="'amplify-field-' + randomPhone"
              autocomplete="tel-country-code"
              aria-label="country code"
              name="country_code"
              :options="dialCodeList!"
              :select-value="dialCode"
            >
            </base-select>
            <base-wrapper
              class="amplify-flex amplify-select__icon"
            >
              <svg
                xmlns="http://www.w3.org/2000/svg"
                fill="currentColor"
                viewBox="0 0 24 24"
                class="amplify-icon"
              >
                <path d="M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z"></path>
              </svg>
            </base-wrapper>
          </base-wrapper>
        </base-wrapper>
      </base-wrapper>
      <base-wrapper class="amplify-field-group__field-wrapper">
      <!--Phone input-->
        <base-input
          class="amplify-input amplify-field-group__control"
          :id="'amplify-field-' + random"
          :autocomplete="autocomplete"
          :name="name"
          :required="required ?? true"
          :type="type"
          :placeholder="placeholder"
          :aria-invalid="hasError"
          :aria-describedBy="describedBy"
          autocapitalize="off"
        ></base-input>
      </base-wrapper>
    </base-wrapper>
  </base-wrapper>
</template>
